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SYSTEM AND METHOD FOR DELIVERY AND 
UPDATING OF REAL-TIME DATA 

Field of the Invention 

The invention relates to a system and method for the delivery and updating 
5 of real-time data. More particularly, the invention is a system and method in which 
a user may obtain real-time data from a supplier or content provider. 

Background of the Invention 

With the explosion in Internet access and usage individuals have discovered 
that they may now receive a large amount of information in their homes and offices 

1 0 almost immediately from any number of sources. These sources include everything 
from the latest news, weather, and sports to stocks, bond and commodity prices. 
Currently, atypical Internet user would have a browser installed in his local computer 
or server such as Internet Explorer™ or Netscape™. Using this browser, the user 
would access an Internet service provider, such as America-On-Line (AOL™), via a 

1 5 modem over the local public switched telephone network (PSTN). Once logged onto 
the Internet server, the user may utilize one of the many search engines, such as 
Yahoo™ or Lycos™, to specify search terms. The user may also use a web crawler, 
spider or robot to attempt to find a product, service or information desired. The 
search engine or web crawler would then respond with a list of web sites which 

20 matched the search terms the user provided. The user would then log onto a web 
site and view the products or services available for sale or receive the information 

2 
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desired. Further, if the user discovers a web site he prefers, the user may store the 
universal resource locator (URL) in a favorites' directory for later quick access. 
Finally, due partly to the availability of the Internet, day trading has become very 
popular. Day traders will often sit in front a monitor and watch as trades in stocks, 
5 bonds, currencies, commodities and options occur on the major markets. These day 
traders will often make numerous purchases and sales in a given day. However, the 
ability to monitor the trading on a major market such as the New York Stock 
Exchange (NYSE) is often difficult for the average user since it entails monitoring 
trading occurring in hundreds of stocks simultaneously. The volume of information 

1 0 that would have to be received would easily exceed the capability of 56K modem. 

To overcome this problem, day traders and others often will turn to broadband 
cable Internet access such as provided by @Home SM or join a service which has 
computers set up at a given location that may be used by their members. If a 
broadband cable Internet service is used, the improvement in throughput can be 

15 significant. This improvement in throughput is possible through the use of coax or 
fiberoptic cable. However, the price is also significantly higher than Internet access 
available through an Internet service provider, such as AOL™, using the local public 
switched telephone network (PSTN). Further, whether using a trading service or a 
broadband cable Internet service, the user is often limited to a single site where they 

20 can access the desired information. 

Recently cellular phone service providers have been making available 
Wireless Access Protocol (WAP) and Hypertext Markup Language (HTML) capable 
cellular phones for Internet access wherever digital cellular phone access is 
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available. Using such a WAP-capable phone, a user no longer is tied to a fixed 
location in order to access the Internet. However, the screen size on such a WAP- 
capable phone is limited. Further, even when using a palm computer or lap top 
connected to a cellular phone, the bandwidth is so limited by the cellular phone that 
5 receiving real-time information is difficult if not impossible. This is particularly the 
case when an entire screen must be refreshed when a single piece of information 
on the screen needs to be changed as would be the case when a HTML refresh tag 
is used. Still further, there is no known system or method that can display real-time 
information in a easily readable form and adjust for screens of dramatically varying 
10 sizes. 

Therefore, what is needed are a system and method in which a user may 
monitor changing events on a real-time basis on a portable device as well as a 
stationary device. This system and method should be able to communicate, adjust 
to and effectively display information any size screen. Further, this system and 
1 5 method should keep data transfer to an absolute minimum so as to use all available 
bandwidth for the critical real-time data that may change at any given moment. 
Further, this system and method should require minimum hardware capability in the 
user portable device so that the size and cost of the user portable device can be kept 
low. 



4 
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Summary of the Invention 

An embodiment of the present invention provides for a method of a method 
of receiving information from a content provider and transmitting the information to 
a user terminal. This method starts by receiving information from the content 
5 provider and then displaying at least a portion of the information on the user terminal. 
The method then monitors the information from the content provider to determine if 
any of the portion of the information being displayed on the user terminal has 
changed. Thereafter, the information from the content provider that has changed is 
updated and transmitted to the user terminal. 

10 Further, an embodiment of the present invention creates a system and 

computer program for receiving real-time data values from a content provider and 
transmitting the real-time data values to a user terminal. This system and computer 
program has a user terminal to receive real-time data values. It also has a real-time 
data server code segment to receive real-time data values from a content provider, 

1 5 determine if the real-time data values have changed from prior real-time and transmit 
the real-time data values to the user terminal when the real-time data values have 
changed from the prior real-time data values. Further, as well as only those real-time 
values that have changed are transmitted, only those real-time data values that are 
currently being displayed on the user terminal are transmitted to the user terminal, 

20 thereby keeping the data transfer required to an absolute minimum. 

These and other features of this device, method and computer program will 
become more apparent from the following description when taken in connection with 
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the accompanying drawings which show, for purposes of illustration only, examples 
in accordance with the present invention. 

Brief Description of the Drawings 

The foregoing and a better understanding of the present invention will become 
5 apparent from the following detailed description of exemplary embodiments and the 
claims when read in connection with the accompanying drawings, all forming a part 
of the disclosure of this invention. While the foregoing and following written and 
illustrated disclosure focuses on disclosing example embodiments of the invention, 
it should be understood that the same is byway of illustration and example only and 
10 the invention is not limited thereto. The spirit and scope of the present invention are 
limited only by the terms of the appended claims. 

The following represents brief descriptions of the drawings, wherein: 
FIG. 1 is an example of an overall system diagram of an embodiment of the 
present invention; 

15 FIG. 2 is an example of a modular configuration diagram illustrating the 

individual modules contained in the real-time data server 20 shown in FIG. 1; 

FIG. 3 is an example of a modular configuration diagram illustrating the 
individual modules contained in the user terminal 10 shown in FIG. 1 and FIG. 2; 
FIG. 4 is an example flowchart illustrating the operations performed by the 
20 main program 120 contained in the real-time data server module 70 shown in FIG. 
2; 
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FIG. 5 is an example flowchart illustrating the operations performed by the 
client connection server module 110 contained in the real-time data server module 
70 shown in FIG. 2; 

FIG. 6 is an example flowchart illustrating the operations performed by the 
5 web engine server module 50 contained in the server 20 shown in FIG. 2; 

FIG. 7 is an example flowchart illustrating the operations performed by the 
data server thread 100 contained in the real-time data server module 70 shown in 
FIG. 2; 

FIG. 8 is an example flowchart illustrating the operations performed by the 
10 source filter module 140 contained in the source filter server module 60 shown in 
FIG. 2; 

FIG. 9 is an example flowchart illustrating the operations performed by the 
embedded applet 620 contained in the user terminal 10 shown in FIG. 3; 

FIG. 10 is an example flowchart illustrating the operations performed by the 
1 5 HTML page and JavaScript 61 0 contained in the user terminal 1 0 shown in FIG. 3; 

FIG. 1 1 is an example screen generated by the embodiments of the present 
invention; and 

FIG. 12 is an example screen generated by the embodiments of the present 
invention. 



20 DETAILED DESCRIPTION 

Before beginning a detailed description of the subject invention, mention of 
the following is in order. When appropriate, like reference numerals and characters 
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maybe used to designate identical, corresponding or similar components in differing 
figure drawings. Further, in the detailed description to follow, exemplary sizes/ 
models/vaiues/ranges may be given, although the present invention is not limited to 
the same. 

5 FIG. 1 is an example of an overall system diagram of an embodiment of the 

present invention showing the three major components. A user terminal 10 is 
employed to interface between the user and a real-time server 20. This user 
terminal 10 may be, but not limited to, WAP-capabfe cellular telephone, a HTML- 
capable cellular telephone, or a processor-based system connected to a cellular 

10 telephone. This processor-based system may be, but not limited to, a palm 
computer, lap-top computer or personal computer. Further, the user terminal 10 is 
not limited to the use of a cellular phone and may also use the public switched 
telephone network (PSTN) or a satellite telephone or any form of communications 
lines such as standard twisted pair phone lines, coax cable and fiber optics. These 

1 5 communications lines may be leased lines including: T1 lines capable of transmitting 
at 1 .54 Mbits/sec; T3 lines capable of transmitting at 45 Mbits/sec; E1 lines capable 
of transmitting at 2.048 Mbits/sec; and E3 lines capable of transmitting at 34 
Mbits/sec. 

Still referring to FIG. 1, the user terminal 10 communicates to the real-time 
20 server 20 which is responsible for delivering real-time data information to the user 
terminal 1 0 from a content provider 30. The content provider 30 may be any supplier 
of real-time information as exemplified by, but not limited to, a stock exchange, 
commodities market, brokerage firm, currency exchange, news wire service, gaming 
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service, and sport event reporting service. The real-time server 20 is discussed in 
further detail in reference to FIGs. 2 and 4 through 8. The user terminal 10 is 
discussed in further detail in reference to FIGs. 3, 9 and 10. 

The modular configuration diagrams shown in FIGs. 2 and 3 as well as the 
5 flowcharts shown in FIGs. 4 through 10 contain software, firmware, processes or 
operations that correspond, for example, to code, sections of code, instructions, 
commands, objects, or the like, of a computer program that is embodied, for 
example, on a storage medium such as floppy disk, CD Rom, EP Rom, RAM, hard 
disk, etc. Further, the computer program can be written in any language such as, 

1 0 but not limited to, for example Java. 

FIG. 2 is an example of a modular configuration diagram illustrating the 
individual modules contained in the real-time server20. The real-time server 20 may 
be implemented as, but not limited to, a Java application running on a Windows 
NT™ server. However, as would be appreciated by one of ordinary skill in the art, 

15 the real-time server 20 may be written in any language equivalent to Java and 
operate under almost any operating system including, but not limited to, Windows 
95™, Windows 98™, Windows NT™, Windows 2000™, Windows CE™, Linux, and 
any version and variation of Unix. One of the functions performed by the real-time 
server 20 is delivery of real-time data to the client terminal 10 from the content 

20 provider 30. The real-time server 20 and user terminal 10 serve to deliver to the user 
or client, data that is fast changing, such as, but not limited to, stock related 
information, and update it on the user terminal 1 0 automatically and within the limited 
and short period of it is available. Further, the embodiments of the present invention 
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are discussed in reference to the receipt and display of stock information. However, 
any reference to stocks or stock information is only by way of example and is not 
intended to limit the scope of the present invention as provided by the claims. 

The real-time server 20 achieves real-time seamless delivery of stock quote 
5 data to the client terminal 10. The user is allowed to create different portfolios and 
to choose different stocks, or sectors appearing in each portfolio. The user saves this 
portfolio, for later use, via the real-time server 20 in database 40. This portfolio 
definition is stored in the user profile information. The user can view the associated 
data for a stock in different views, the views include a stock information view, news 
10 article view, stock intra-day view, and trading information view. Examples of these 
views are illustrated and discussed in further detail in reference to FIG. 11 and 12 
ahead. 

Still referring to FIG. 2, a source filter server module 60 is used to receive real- 
time data and maintain it for quick access. The source filter server module 60 uses 

15 a source filter module 140 and a Hash table 130 to accomplish reception and quick 
retrieval of real-time data. The source filter module 140 may receive, but not limited 
to, an XML (Extensible Markup Language) stock feed from the content provider 30 
and parses it into a Hash Table 1 30 which contains the latest values for each stock. 
A key is associated with each stock entry and used to access the hash table 130. 

20 The key allows for direct access to the associated stock data without the requirement 
of searching or sorting the data. A real-time data server module 70 communicates 
with the source server filter module 60 using remote method invocation (RMI). RMI 
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is a remote procedure call (RPC), which allows Java objects (software components) 
stored in the network to be run remotely. 

Still referring to FIG. 2, the real-time data server module 70 employees at 
least three modules including a data server thread 1 00, a client connection 1 1 0 and 
5 a main program 120. The client connection server module 110 listens or monitors 
the ports to the user terminals 1 0 for incoming connections and launches a dedicated 
data server thread 100 to serve each connection. Therefore, each user terminal 10 
has at least one dedicated data server thread 100. The data server thread 100 uses 
RMI to monitor data being maintained by the source filter server module 140 in hash 

10 table 130. The data server thread 100 registers itself as an observer for keys, based 
on portfolio selection or other input from the user terminal 10, and is notified when 
the values change for those keys by the source filter sever module 60. Upon 
notification of such a change the data server thread 1 00 retrieves the new data using 
RMI and if the values are different from the previously known values, sends a packet 

15 of data back to the user terminal 1 0. 

Still referring FIG. 2, a web engine server module 50 is used to communicate 
between the user terminal 1 0 and the database 40. The web engine server module 
50 has at least two components which include a web server module 80 and a 
pagination engine module 90. The web engine module 50 retrieves paginated HTML 

20 pages for the portfolio selected by the user with an embedded applet 620, shown in 
FIG. 3, that is downloaded to the user terminal 10. The HTML page and JavaScript 
610, shown in FIG. 3, is created by the pagination engine module 90 when the user 
requests a particular portfolio. The HTML page and JavaScript 61 0 contains the table 
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indicating where the data is to be displayed on the user terminal 1 0, and contains the 
embedded applet 620, shown in FIG. 3. Thus, using this table, it is possible to 
accommodate the data to different size screens on the user terminal 10. The HTML 
page and JavaScript 610 also contains the initialization parameters for the 
5 embedded applet 620 as well the JavaScript code for navigation as well as 
document object module (DOM) manipulation of the HTML page and JavaScript 61 0. 

FIG. 3 is an example of a modular configuration diagram illustrating the 
individual modules contained in the user terminal 10, shown in FIG. 1 and FIG. 2. 
The user terminal 10 includes a HTML Page and JavaScript 610 and an embedded 

10 applet 620. The JavaScript portion of the HTML page and JavaScript 610 traps any 
keyboard event entered by the user and performs basic navigation. If a need exists 
to change the page, the JavaScript of the HTML page and JavaScript 610 calls the 
embedded applet 620 to change the page of active keys, and the embedded applet 
620 responds with an indication of whether it is possible to do so. The embedded 

1 5 applet 620 transmits to its corresponding data server thread 1 00 in the real-time data 
sever module 70, shown in FIG. 2, the new active keys to monitor. The embedded 
applet 620, on receiving appropriate data from the data server thread 1 00, changes 
the displayed data on the user terminal 10 window using a JavaScript method for a 
document object module (DOM) manipulation. 

20 A detailed discussion will now be supplied for the modules shown in FIG. 2 

contained in real-time server 20. As previously mentioned, the flowcharts shown in 
FIGs. 4 through 10 contain software, firmware, processes or operations that 
correspond, for example, to code, sections of code, instructions, commands, objects, 
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or the like, of a computer program that is embodied, for example, on a storage 
medium such as floppy disk, CD Rom, EP Rom, RAM, hard disk, etc. 

FIG. 4 is an example flowchart illustrating the operations and processes 
performed by the main program 120 contained in the real-time data server module 
5 70 shown in FIG. 2. The main program 120 begins execution in operation 160 and 
proceeds to operation 170 at which point in time it launches the client connection 
server module 110, shown in FIG. 2 and further discussed in reference to FIG. 5. 
Thereafter, in operation 180, the main program 120 generates an administrative 
panel or window which allows an administrator to shut down operations in the real- 

1 0 time server 20. In operation 1 90, a determination is made whether the administrator 
has engaged the shutdown. If the administrator has not activated the shutdown 
function then operation 190 is repeated until the administrator does activate the 
shutdown process. If a shutdown is activated then processing proceeds to operation 
200 where the client connection server module 120 is shutdown. Then in operation 

15 210, the main program 120 stops execution. 

FIG. 5 is an example flowchart illustrating the operations performed by the 
client connection server module 110 contained in the real-time data server module 
70 shown in FIG. 2. The client connection server module 1 1 0 is started, in operation 
240, by the main program 1 20 in operation 1 70 shown in FIG. 1 70. In operation 250, 

20 the client connection server module 110 monitors to determine if a connection 
request has been received. If no connection request has been received then 
processing proceeds to operation 270. However, if a connection request has been 
made then processing proceeds to operation 260 where a data thread server 100 is 
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spawned. Thereafter, processing proceeds to operation 270 where it is determined 
whether a shutdown processing request has been activated. If no shutdown 
processing request has been made then processing returns to operation 250 where 
the processing discussed above is repeated and any additional connections 
5 requested are opened until a shutdown request is received. If such a shutdown 
request is received, then processing proceeds to operation 280 where all active 
client connections are shutdown. Once all active connections are shutdown in 
operation 280, then the client connection server module 110 stops execution in 
operation 290. 

10 FIG. 6 is an example flowchart illustrating the operations performed by the 

web engine server module 50 contained in the server 20 shown in FIG. 2. To 
summarize the web engine server module 50 fetches a portfolio and returns a 
paginated portfolio page which has an embedded applet 620. The web engine 
server module 50 is activated in operation 310 and processing immediately proceeds 

1 5 to operation 320. In operation 320, the user defined portfolio containing the key the 
user wants to view is retrieved from database 40. Then in operation 330, the 
pagination engine module 90 generates a paginated HTML and JavaScript 610 for 
the portfolio containing the embedded applet 620. Processing proceeds to operation 
340 where, in response to the portfolio request, a paginated HTML page is 

20 transmitted to the user terminal 10. Thereafter, processing of the portfolio request 
is stopped by terminating execution of the web engine server module 50 in operation 
350. 
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FIG. 7 is an example flowchart illustrating the operations performed by the 
data server thread 100 contained in the real-time data server module 70 shown in 
FIG. 2. Data thread server 1 00 begins execution in operation 400 when the client 
connection server module 110 spawns the data thread in operation 260 as shown 
5 in FIG. 5. Then in operation 410, the keys in the portfolio are read by the data server 
thread 100. In operation 420, the monitoring of the values for all keys is done as 
previously discussed using an RMI. In operation 430, the currently active keys are 
received from the user terminal 10. Thereafter, it is determined in operation 440 if 
a shutdown activation request has occurred. If it is determined in operation 520 that 

10 a shutdown has been requested, then processing proceeds to operation 520 where 
the embedded applet 620 is informed of the shutdown and the connection is closed. 
Thereafter, if a shutdown was requested, then processing proceeds to operation 530 
where the execution of the data server thread 100 is terminated. 

Still referring to FIG. 7, if operation 440 determines that a shutdown was not 

15 activated then processing proceeds to operation 450 where it is determined if the 
currently active keys have changed, if the currently active keys have changed, then 
processing proceeds to operation 460 where the update buffer is flushed and the 
values for the active keys are added to the update buffer. The update buffer may 
reside in memory or any suitable storage device including database 40. Once 

20 operation 460 has completed or it is determined in operation 450 that the active keys 
are not changed then processing proceeds to operation 470. In operation, 470 the 
data server thread 100 determines if any updates are pending. If updates are 
pending then processing proceeds to operation 480 where an update packet is 

15 
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created and sent to the user terminal 10. In this manner, only values that have 
changed are sent to the user terminal 10 and the volume of data is kept to a 
minimum. Once the packet is sent to the user terminal 10, processing proceeds 
back to operation 430 where the succeeding operations are repeated. 
5 Still referring to FIG. 7, if it is determined in operation 480 that no updates are 

pending then processing proceeds to operation 490 where it is determined if an 
update notification has been received from the source filter module 140 through the 
hash table 130. Such an update notification would indicate that a value to a 
monitored key has changed and the user terminal 10 may need to be updated. If 

10 operation 490 determines that no update notification has been received then 
processing proceeds back to operation 430 where the succeeding processes are 
repeated. However, if operation 490 determines an update notification was received 
then processing proceeds to operation 500 where it is determined if the key with 
which this update notification is associated with is currently active. If the key is not 

15 currently active then there exists no need to update the user terminal 10 and 
processing again returns to operation 430. However, if the key is currently active 
then processing proceeds to operation 510 where the update value is added to the 
update buffer where it will be transmitted to the user terminal in operation 480. 

FIG. 8 is an example flowchart illustrating the operations performed by the 

20 source filter module 140 contained in the source filter server module 60 shown in 
FIG. 2. The source filter server module 60 is activated upon startup of the server20 
and creates a separate source filter module 140 for each content provider to which 
the server 20 is connected. The source filter module 140 is activated in operation 
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560 and processing immediately proceeds to operation 570. In operation 570, the 
source filter module 140, on a periodic or predetermined time basis, retrieves key 
data from the content provider 30. For example, every few seconds the source filter 
module 140 could retrieve the last trading price for every stock listed on a content 
5 provider 30 such as the New York Stock Exchange. Then in operation 580, the 
source filter module 140 determines if any of the data associated with the keys in the 
hash table 130 has changed. If no values for any keys have changed, then 
processing branches back to operation 570 and repeats again. However, if a value 
for a key has changed the data server thread 100 that is listening for updates is 
10 notified of the change in the value of data associated with the key. Thereafter, 
processing proceeds back to operation 570 and repeats until the server 20 is 
shutdown. 

FIG. 9 is an example flowchart illustrating the operations performed by the 
embedded applet 620 contained in the user terminal 10 shown in FIG. 3. The 

1 5 embedded applet 620 is generated by web engine server module in conjunction with 
the pagination engine module 90 in operation 330 shown in FIG. 6. Upon activation 
of the embedded applet 620 in operation 640, processing immediately proceeds to 
operation 650 where the keys and pagination parameters are initialized. Thereafter, 
in operation 660, the socket connection is initialized and the associated data server 

20 thread 100 is notified of the keys and those that are active. In operation 670, a 
determination is made whether a page change is needed. Such a page change 
would be needed when a user enters commands to monitor a different portfolio, a 
different stock or set of stocks, or a different event. If such a page change is needed 
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then processing proceeds to operation 670 where the active key set is changed and 
the data server thread 100 is informed of the change in the page. 

Regardless of whether a page change is required processing for the 
embedded applet 620 proceeds to operation where a determination is made as to 
5 whether new data has been received from the data server thread 1 00 as a result of 
a change is an active key. If new data has been received then processing proceeds 
to operation 690 where the corresponding row on the screen of the user terminal 10 
is updated. Examples of screens displayed on the user terminal are provided in 
FIGs. 11 and 12. 

1 0 Whether any new data was received, processing continues to operation 700 

where it is determined whether a stop request has been entered by the user on the 
user terminal 10. If such a stop request has not been entered, then processing 
proceeds back to operation 670 and repeats. However, if a stop request has been 
received then processing proceeds operation 710 where the data server thread 100 

15 is informed and the connection is closed. Thereafter, processing proceeds to 
operation 720 where the execution of the embedded applet 620 is terminated. 

FIG. 10 is an example flowchart illustrating the operations performed by the 
HTML page and JavaScript 610 contained in the user terminal 10 shown in FIG. 3. 
The HTML page and JavaScript 610 is generated by web engine server module 50 

20 in conjunction with the pagination engine module 90 in operation 330 and 340 shown 
in FIG. 6. Upon activation of the HTML page and JavaScript 610 in operation 750, 
processing immediately proceeds to operation 760 where the keys and pagination 
parameters are initialized. Thereafter, in operation 770 a determination is made if 
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a navigation event has occurred. A navigation event is an event caused by the user 
that would require some change to occur such as, but not limited to the selecting of 
a menu bar or the request for a new piece of data to be displayed. If it is determined 
in operation 770 that a navigation event has not occurred then processing enters a 
5 loop process wherein the HTML page and JavaScript 610 branches back to 
operation 770 until such a navigation event is detected. If a navigation event is 
detected then processing proceeds to operation 780 where it is determined if a page 
change is necessary. If such a page change is not desired then processing 
proceeds to operation 790 in order to place a highlighted bar on the screen and allow 

10 the user to move it and make a selection. Examples of such highlighted bars may 
be found illustrated in the example screens found FIGs. 11 and 12. If a page 
change is necessary due to a user selection, then processing proceeds to operation 
800 where the embedded applet 620 is informed of the page change. Thereafter, 
HTML page and JavaScript 610 continues to loop back to operation 770 where it 

1 5 repeats processing until the user moves out of the portfolio page, thereby halting the 
monitoring of real-time values and causing the embedded applet 620 to stop 
execution. 

FIG. 11 is an example screen 900 generated by the embodiments of the 
present invention in which stock data is shown as displayed on user terminal 10. 
20 Screen 900 shows an example stock portfolio selected by a user when employing 
the embodiments of the present invention. The example screen 900 shown in Fig. 
1 1 is provided to illustrate a user portfolio of stocks and market data related to the 
stocks as would be shown in a typical screen size. 
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FIG. 12 is an example screen 900 generated by the embodiment of present 
invention showing stock prices on a smaller screen such as may be used in WAP- 
capable cellular telephone or a palm computer. As can be seen in Fig. 12, the 
volume of data in screen size is adjusted in order to accommodate smaller display 
5 area. 

Using the foregoing embodiments of the present invention, a user is able to 
receive rapidly changing real-time data over a relatively slow communications line 
and view this data on a relatively small screen such as found in a WAP-capable 
phone. This is possible due to the embodiments of the present invention being able 

10 to maintain a low volume of traffic throughput over the communications line. This is 
possible since only data that has changed is transmitted and not the entire screen. 
A hash table is used to identify real time data values that have changed and only 
those real-time data values that are associated with active keys are transmitted to 
the user terminal. Screens of various sizes may be identified and compensated for 

15 by using a table associated with each screen size. Further, an entire screen of data 
is only transmitted once upon start up and thereafter only real-time data values that 
have changed are transmitted. 

White we have shown and described only a few examples herein, it is 
understood that numerous changes and modifications as known to those skilled in 

20 the art could be made to the present invention. For example, any type of real-time 
data may be retrieved and transmitted to users on a selective basis. The 
embodiments present invention are not confined to stock prices. Further, any type 
of direct method of record retrieval may be utilized instead of hash table 130. 
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Therefore, we do not wish to be limited to the details shown and described herein, 
but intend to coverall such changes modifications as are encompassed by the scope 
of the appended claims. 
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CLAIMS 



We Claim: 



1 1. A method of receiving information from a content provider and 

2 transmitting the information to a user terminal, comprising: 

3 receiving information from the content provider; 

4 displaying at least a portion of the information on the user terminal; 

5 monitoring the information from the content provider to determine if any of the 

6 portion of the information being displayed on the user terminal has changed; 

7 updating the information from the content provider that has changed; and 

8 transmitting the information from the content provider that has changed to the 

9 user terminal. 

1 2. The method recited in claim 1, wherein the information comprises a 

2 plurality of real-time data values from the content provider. 

1 3. The method recited in claim 2, wherein the updating of information from 

2 the content provider further comprises: 

3 accessing a hash table containing a plurality of prior real-time data values 

4 using a plurality of keys associated with the plurality of real-time data values; 
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5 determining whether the plurality of real-time data values received from 

6 content provider has changed from the prior plurality of real-time data values 

7 contained in the hash table; and 

8 updating the prior plurality real-time data values contained in the hash table 



9 with the plurality of real-time values received from the content provider when the 

10 plurality of real-time data values received from content provider has changed from 

1 1 the plurality of prior real-time data values contained in the hash table. 



1 4. The method recited in claim 3, wherein the transmitting of the plurality 

2 of real-time data values that have been updated in the hash table to the user 

3 terminal further comprises: 

4 activating a data thread when a real-time data value of the plurality of prior 

5 real-time data values is updated in the hash table; 

6 determining the position on a screen in the userterminal corresponding to the 

7 real-time data value; 

8 transmitting the real-time data value to the user terminal; and 

9 displaying the time real-time data value on the screen in the user terminal in 
10 the position indicated. 

1 5. The method recited in claim 4, wherein the data thread is activated using 

2 remote method invocation. 
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1 6. The method recited in claim 3, further comprising: 

2 requesting a connection by the user terminal; 

3 spawning a data server thread; 

4 retrieving a user defined portfolio by the data thread containing a plurality of 

5 keys; 

6 generating activated HTML page containing an embedded applet and 

7 downloading to the user terminal; and 

8 monitoring the plurality of keys contained in the user defined portfolio and 

9 identifying currently active keys of said of the plurality of keys. 

1 7. The method recited in claim 6, comprising: 

2 reading the currently active keys; 

3 determining if the currently active keys have changed; 

4 updating the hash table with the real-time data values for currently active 

5 keys; and 

6 downloading real-time values for the currently active keys that have changed 

7 from the hash table to the user terminal. 

1 8. The method recited in claim 7, comprising: 

2 determining whether a shutdown request was made; and 

3 disconnecting all connections to the userterminal when the shutdown request 

4 was made. 
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1 9. The method recited in claim 8, comprising: 

2 retrieving the plurality of real-time data values on a periodic basis. 

1 10. The method recited in claim 9, comprising: 

2 notifying data server thread when a real-time data value of the plurality of data 

3 that values has changed. 

1 11. The method recited and claim 6, comprising: 

2 activating an embedded applet received from the data server thread in the 

3 user terminal; 

4 determining whether a page changed is required; 

5 informing to the data server thread of a plurality of new active keys; 

6 receiving the plurality of real-time data values from the data server thread; and 

7 updating the screen on the userterminal associated with each time data value 

8 of the plurality of real-time data values. 

1 12. A computer program executable by computer and embodied on a 

2 computer readable medium for receiving a plurality of real-time data values from a 

3 content provider and transmitting the real-time data values to a user terminal, 

4 comprising: 

5 a user terminal code segment to receive real-time data values; and 

6 a real-time data server code segment to receive real-time data values from 

7 a content provider, determine if the real-time data values have changed from prior 
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8 real-time and transmit the real-time data values to the user terminal when the 

9 real-time data values have changed from the prior real-time data values. 

1 13. The computer program recited in claim 12, wherein the real-time data 

2 server code segment further comprises: 

3 a hash table storing the prior real-time data values and being updated when 

4 the real-time data values from the content provider have changed from the prior real 

5 -time data values. 

1 14. The computer program recited in claim 13, wherein the real-time data 

2 server further comprises: 

3 a web engine server module code segment to access a database having a 



4 portfolio generated by a user and generate an HTML page and applet, wherein upon 

5 receipt of a connection request from the user terminal the web engine server module 

6 code segment downloads the HTML page and applet to the user terminal code 

7 segment. 



1 15. The computer program recited in claim 13, wherein the real-time data 

2 server further comprises: 

3 a source filter server module code segment to receive real-time data values 

4 from a content provider and determine if the real-time data values have changed 

5 from prior real-time data values stored and table, and activate a data thread code 
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6 segment when the real-time data values have changed from prior real-time data 

7 values. 



1 16. The computer program recited in claim 15, wherein the real-time data 

2 server further comprises: 

3 a real time data server module code segment to communicate between the 

4 user terminal code segment and the source filter server module code segment 

5 through the data server thread code segment. 

1 17. The computer program recited in claim 16, where and source filter 

2 server module further comprises: 

3 a source filter module code segment to receive the real-time data values from 

4 the values content provider; and update the hash table. 

1 18. The computer program recited in claim 13, wherein the user terminal 

2 further comprises: 

3 a HTML page and JavaScript module code segment to display a screen on 

4 the user terminal code segment; and 

5 an embedded applet code segment to update the screen for the user terminal 

6 code segment when the time data values are received from the real-time data server. 

1 19. The computer program recited in claim 13, wherein the web engine 

2 server module further comprises: 

27 



ATSK Reference No.: 017.38083x00 
Nokia Reference No.: 28154 



3 a web server module code segment to communicate to the user terminal code 

4 segment and retrieve a portfolio specified by the user terminal code segment from 

5 a database; and 

6 a pagination engine module code segment, in communication with the web 

7 server module code segment, to create the HTML page and applet code segment 

8 based on the portfolio selected and the size of the screen on a user terminal. 

1 20. A system to receive a plurality of real-time data values from a content 

2 provider and transmitting the real-time data values to a user terminal, comprising: 

3 a user terminal to receive real-time data values; and 

4 a real-time data server to receive real-time data values from a content 



5 provider, determine if the real-time data values have changed from prior real-time 

6 data values and transmit the real-time data values to the user terminal when the 

7 real-time data values have changed from the prior real-time data values. 



1 21. The system recited in claim 20, wherein the real-time data server 

2 further comprises: 

3 a hash table storing the prior real-time data values and being updated when 

4 the real-time data values from the content provider have changed from the prior real 

5 -time data values. 

1 22. The system recited in claim 21 , wherein the real-time data serverfurther 

2 comprises: 
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3 a web engine server module to access a database having a portfolio 

4 generated by a user and generate an HTML page and applet, wherein upon receipt 

5 of a connection request from the user terminal the web engine server module 

6 downloads the HTML page and applet to the user terminal. 

1 23. The system recited in claim 21 , wherein the real-time data server further 

2 comprises: 

3 a source filter server module to receive real-time data values from the content 

4 provider and determine if the real-time data values have changed from prior real-time 

5 data values stored and table, and activate a data thread when the real-time data 

6 values have changed from prior real-time data values. 



1 24. The system recited in claim 23, wherein the real-time data server further 

2 comprises: 

3 a real time data server module to communicate between the user terminal and 

4 the source filter server module through the data server thread. 

1 25. The system recited in claim 24, where and source filter server module 

2 further comprises: 

3 a source filter module to receive the real-time data values from the values 

4 content provider; and update hash table. 
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1 26. The system recited in claim 21, wherein the user terminal further 

2 comprises: 

3 a HTML page Java scripts to display a screen on the user terminal and; and 

4 an embedded applet to update the screen on the terminal when the time data 

5 values are received from the real-time data server. 



1 27. The computer program recited in claim 22, wherein the web engine 

2 server module further comprises: 

3 a web server module to communicate to the user terminal and retrieve a 

4 portfolio specified by the user terminal from a database; and 

5 a pagination engine module, in communication with the web server module, 

6 to create the HTML page and applet based on the portfolio selected and the size of 

7 the screen on the user terminal. 
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Abstract of the Disclosure 

A system, method and computer program for receiving real-time data from 
a content provider and delivering it to a user terminal while using the minimum 
amount of communication bandwidth possible. This real-time data may take the form 
5 of any frequently changing data such as stock prices. The user logs on the system 
and specifies a portfolio or stocks he is interested viewing. The user may also select 
active keys which are to be continuously observed. Upon receipt of the real-time 
data from the content provider, the system, method and computer program 
determine whether the real-time data has changed from the last update. If no 

10 changes have occurred to the real-time data values or the real-time data is not 
associated the currently active keys then there is no real-time data downloaded to 
the user. Only if there is a change in real-time data values associated with active 
currently active keys will the real-time data be transmitted to the user terminal. 
Further, this system, method and computer program may communicate to any 

15 possible userterminal no matter what size screen since the position of each changed 
real-time data value is specified based on screen size the user terminal is using. 
Therefore, a user may monitor continuously changing real-time data values while 
using a mobile device such as a digital cellular phone. 
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